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AMENDMENTS TO THE CLAIMS 

1 . (Previously Presented) A method of optimizing computer program code where 
the computer program code includes a plurality of statements, the method comprising 
the steps of: 

identifying a keyword statement, wherein the keyword statement includes a 
keyword and a data reference; 

sequentially locating each keyword statement in the program code; 

converting in the program code, each data reference in each keyword 
statement to a data array reference; 

searching the program code for the keyword statement after the conversion of 
each data reference to a data array reference; 

determining if the keyword statement begins a repeating pattern of statements 
in the program code; and 

replacing the repeating pattern of statements with a program loop equivalent to 
the repeating pattern of statements. 

Claim 2. (Cancelled) 

3. (Previously Presented) The method of optimizing as set forth in claim 1 
wherein the converting includes assigning an array index value to the data array 
reference where each located keyword statement is assigned a next sequential value 
of the array index value. 

4. (Currently Amended) The method of optimizing as set forth in claim 3 wherein 
the determining step further includes: 

comparing data array references of two converted keyword statements from the 
program code; and 

determining if the array index values from the data array references match in 
size and sequential order. 
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5. (Currently amended) The method of optimizing as set forth in claim 1 wherein 
the determining step includes: 

determining a first pattern of statements in the program code beginning with a 
first converted keyword statement and ending with a statement preceding a second 
converted keyword statement that sequentially appears in the program code after the 
first converted keyword statement; 

determining a second pattern of statements in the program code beginning with 
the second converted keyword statement and ending with a statement preceding a 
third converted keyword statement that sequentially appears in the program code after 
the second converted keyword statement; and 

comparing the first pattern of statements to the second pattern of statements; 

and 

setting the first pattern of statements as a repeating pattern if the first and 
second pattern of statements substantially match. 

6. (Original) The method of optimizing as set forth in claim 1 wherein the 
replacing step includes: 

generating loop code for executing a loop within the source code at a location 
of the repeating pattern of statements; 

inserting one instance of the repeating pattern of statements within the loop 
code; and 

defining the loop code to iterate a number of times equal to a number of 
instances of the repeating pattern. 

7. (Original) The method of optimizing as set forth in claim 1 wherein the 
keyword statement is identified from a predetermined keyword statement. 

8. (Original) The method of optimizing as set forth in claim 1 wherein the 
keyword statement is identified from a selection made by a user. 
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9. (Original) The method of optimizing as set forth in claim 1 further including 
identifying a plurality of keyword statements and repeating the method for optimizing 
for each of the plurality of keyword statements. 



Claims 10-15. (Cancelled) 

16. (Previously Presented) A process for optimizing a software code that includes 
a plurality of statements, the process comprising the steps of: 

selecting at least one keyword statement, wherein the keyword statement 
includes a keyword and a data reference; 

converting in the software code, each data reference of each keyword 
statement to a data array reference, the data array reference being loaded with values 
of the converted data references; 

locating, after conversion of each data reference to an array reference, multiple 
occurrences of a code pattern within the software code where the multiple 
occurrences appear sequentially to each other in the software code; 

generating a program loop that executes one occurrence of the code pattern a 
number of times to produce an equivalent result as executing the multiple occurrences 
of the code pattern; and 

replacing the multiple occurrences of the code pattern in the software code with 
the program loop. 



17. (Original) The process for optimizing a software code as set forth in claim 16 
further including: 

selecting a keyword statement; and 

defining the code pattern based on the keyword statement. 
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18. (Original) The process for optimizing a software code as set forth in claim 17 
wherein the defining step includes: 

locating a first instance of the keyword statement in the software code; 

defining a first code pattern to include at least the first instance of the keyword 
statement; 

adding subsequent non-keyword statements to the first code pattern until a 
second instance of the keyword statement appears in the software code; 

defining a second code pattern to include at least the second instance of the 
keyword statement; 

adding subsequent non-keyword statements to the second code pattern until a 
third instance of the keyword statement appears in the software code or until a 
number of the subsequent non-keyword statements added equal a number of the 
subsequent non-keyword statements in the first code pattern; and 

comparing the first code pattern with the second code pattern to determine if 
the second code pattern is a multiple occurrence of the first code pattern. 

Claim 19. (Cancelled) 

20. (Original) The process for optimizing a software code as set forth in claim 16 
wherein the generating a program loop step includes generating a looping instruction. 

21 . (Previously Presented) A method of optimizing computer program source 
code, wherein the computer program source code includes a plurality of statements, 
comprising: 

searching the program source code for a keyword statement, wherein the 
keyword statement includes a keyword and an associated data value; 

replacing in each keyword statement in the program source code, each data 
value with a selected array name and an associated array index specification sized to 
store the associated data value; 



5 



X-779 US 
09/755,502 



PATENT 
Conf. No. 5243 



determining, after the replacing of each data value, whether the keyword 
statement begins a first pattern of one or more statements in the program code that is 
repeated in a second set of statements in the program source code; and 

replacing the first pattern of one or more statements and the second set of 
statements in the program source code with a loop control statement and at least one 
loop-body statement that together define a function equivalent to the first pattern and 
second set of statements. 

Claim 22. (Cancelled) 

23. (Previously Presented) The method of claim 21 , wherein the replacing step 
includes specifying in each array index specification a non-overlapping range of array 
index values. 

24. (Previously Presented) The method of claim 23, wherein the specifying step 
includes specifying sequential ranges of array index values in array index 
specifications associated with keyword statements that occur sequentially in the 
program source code. 

25. (Previously Presented) The method of claim 24, further comprising, wherein 
the replacing step includes generating the loop control statement and the at least one 
loop body statement to reference the array name and each sequential, non- 
overlapping range of index values. 
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26. (Previously Presented) An apparatus for optimizing computer program source 
code, wherein the computer program source code includes a plurality of statements, 
comprising: 

means for searching the program source code for a keyword statemfent^ 
wherein the keyword statement includes a keyword and an associated data value; 

means for replacing in each keyword statement in the program source code, 
each data value with a selected array name and an associated array index 
specification sized to store the associated data value; 

means for determining, after replacement of each data value, whether the 
keyword statement begins a first pattern of one or more statements in the program 
code that is repeated in a second set of statements in the program source code; and 

means for replacing the first pattern of one or more statements and the second 
set of statements in the program source code with a loop control statement and at 
least one loop-body statement that together define a function equivalent to the first 
pattern and second set of statements. 

Claim 27. (Cancelled) 
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